<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        // 1.问
        // console.log(num);
        // 2.问
        console.log(num);//undefind   坑1
        var num = 10;
        // 相当于执行了以下代码
        var num;
        console.log(nnum);
        num = 10;
        // 3.问
        fn();
        function fn() {
            console.log(11);
        }
        // 4.问
        fun();//报错  坑2
        var fun = function () {
            console.log(22);
        }
        // 函数表达式，调用必须写在函数表达式的下面
        // 相当于执行了以下代码
        var fun;
        fun();
        fun = function () {
            console.log(22);
        }

        // 1.我们js引擎分两步， 预解析   代码执行
        // (1)预解析js引擎 会把js里面所有的var  还有function提升到当前的作用域的最前面
        // (2).代码执行   按照代码的顺序性上到下执行
        // 2.预解析分为变量预解析(变量提升)和函数解析(函数提升)
        // (1)变量提升，就是把所有的变量声明提升到当前的作用域的最前面  不提供赋值操作
        // (2)函数提升 就是把所有的函数声明提升到当前作用域的最前面  不用调用函数


    </script>
</head>

<body>

</body>

</html>